<!DOCTYPE html>
<html>

<head>

<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes">
<title>README</title>


<style type="text/css">
body {
  font-family: Helvetica, arial, sans-serif;
  font-size: 14px;
  line-height: 1.6;
  padding-top: 10px;
  padding-bottom: 10px;
  background-color: white;
  padding: 30px; }

body > *:first-child {
  margin-top: 0 !important; }
body > *:last-child {
  margin-bottom: 0 !important; }

a {
  color: #4183C4; }
a.absent {
  color: #cc0000; }
a.anchor {
  display: block;
  padding-left: 30px;
  margin-left: -30px;
  cursor: pointer;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0; }

h1, h2, h3, h4, h5, h6 {
  margin: 20px 0 10px;
  padding: 0;
  font-weight: bold;
  -webkit-font-smoothing: antialiased;
  cursor: text;
  position: relative; }

h1:hover a.anchor, h2:hover a.anchor, h3:hover a.anchor, h4:hover a.anchor, h5:hover a.anchor, h6:hover a.anchor {
  background: url() no-repeat 10px center;
  text-decoration: none; }

h1 tt, h1 code {
  font-size: inherit; }

h2 tt, h2 code {
  font-size: inherit; }

h3 tt, h3 code {
  font-size: inherit; }

h4 tt, h4 code {
  font-size: inherit; }

h5 tt, h5 code {
  font-size: inherit; }

h6 tt, h6 code {
  font-size: inherit; }

h1 {
  font-size: 28px;
  color: black; }

h2 {
  font-size: 24px;
  border-bottom: 1px solid #cccccc;
  color: black; }

h3 {
  font-size: 18px; }

h4 {
  font-size: 16px; }

h5 {
  font-size: 14px; }

h6 {
  color: #777777;
  font-size: 14px; }

p, blockquote, ul, ol, dl, li, table, pre {
  margin: 15px 0; }

hr {
  background: transparent url() repeat-x 0 0;
  border: 0 none;
  color: #cccccc;
  height: 4px;
  padding: 0;
}

body > h2:first-child {
  margin-top: 0;
  padding-top: 0; }
body > h1:first-child {
  margin-top: 0;
  padding-top: 0; }
  body > h1:first-child + h2 {
    margin-top: 0;
    padding-top: 0; }
body > h3:first-child, body > h4:first-child, body > h5:first-child, body > h6:first-child {
  margin-top: 0;
  padding-top: 0; }

a:first-child h1, a:first-child h2, a:first-child h3, a:first-child h4, a:first-child h5, a:first-child h6 {
  margin-top: 0;
  padding-top: 0; }

h1 p, h2 p, h3 p, h4 p, h5 p, h6 p {
  margin-top: 0; }

li p.first {
  display: inline-block; }
li {
  margin: 0; }
ul, ol {
  padding-left: 30px; }

ul :first-child, ol :first-child {
  margin-top: 0; }

dl {
  padding: 0; }
  dl dt {
    font-size: 14px;
    font-weight: bold;
    font-style: italic;
    padding: 0;
    margin: 15px 0 5px; }
    dl dt:first-child {
      padding: 0; }
    dl dt > :first-child {
      margin-top: 0; }
    dl dt > :last-child {
      margin-bottom: 0; }
  dl dd {
    margin: 0 0 15px;
    padding: 0 15px; }
    dl dd > :first-child {
      margin-top: 0; }
    dl dd > :last-child {
      margin-bottom: 0; }

blockquote {
  border-left: 4px solid #dddddd;
  padding: 0 15px;
  color: #777777; }
  blockquote > :first-child {
    margin-top: 0; }
  blockquote > :last-child {
    margin-bottom: 0; }

table {
  padding: 0;border-collapse: collapse; }
  table tr {
    border-top: 1px solid #cccccc;
    background-color: white;
    margin: 0;
    padding: 0; }
    table tr:nth-child(2n) {
      background-color: #f8f8f8; }
    table tr th {
      font-weight: bold;
      border: 1px solid #cccccc;
      margin: 0;
      padding: 6px 13px; }
    table tr td {
      border: 1px solid #cccccc;
      margin: 0;
      padding: 6px 13px; }
    table tr th :first-child, table tr td :first-child {
      margin-top: 0; }
    table tr th :last-child, table tr td :last-child {
      margin-bottom: 0; }

img {
  max-width: 100%; }

span.frame {
  display: block;
  overflow: hidden; }
  span.frame > span {
    border: 1px solid #dddddd;
    display: block;
    float: left;
    overflow: hidden;
    margin: 13px 0 0;
    padding: 7px;
    width: auto; }
  span.frame span img {
    display: block;
    float: left; }
  span.frame span span {
    clear: both;
    color: #333333;
    display: block;
    padding: 5px 0 0; }
span.align-center {
  display: block;
  overflow: hidden;
  clear: both; }
  span.align-center > span {
    display: block;
    overflow: hidden;
    margin: 13px auto 0;
    text-align: center; }
  span.align-center span img {
    margin: 0 auto;
    text-align: center; }
span.align-right {
  display: block;
  overflow: hidden;
  clear: both; }
  span.align-right > span {
    display: block;
    overflow: hidden;
    margin: 13px 0 0;
    text-align: right; }
  span.align-right span img {
    margin: 0;
    text-align: right; }
span.float-left {
  display: block;
  margin-right: 13px;
  overflow: hidden;
  float: left; }
  span.float-left span {
    margin: 13px 0 0; }
span.float-right {
  display: block;
  margin-left: 13px;
  overflow: hidden;
  float: right; }
  span.float-right > span {
    display: block;
    overflow: hidden;
    margin: 13px auto 0;
    text-align: right; }

code, tt {
  margin: 0 2px;
  padding: 0 5px;
  white-space: nowrap;
  border: 1px solid #eaeaea;
  background-color: #f8f8f8;
  border-radius: 3px; }

pre code {
  margin: 0;
  padding: 0;
  white-space: pre;
  border: none;
  background: transparent; }

.highlight pre {
  background-color: #f8f8f8;
  border: 1px solid #cccccc;
  font-size: 13px;
  line-height: 19px;
  overflow: auto;
  padding: 6px 10px;
  border-radius: 3px; }

pre {
  background-color: #f8f8f8;
  border: 1px solid #cccccc;
  font-size: 13px;
  line-height: 19px;
  overflow: auto;
  padding: 6px 10px;
  border-radius: 3px; }
  pre code, pre tt {
    background-color: transparent;
    border: none; }

sup {
    font-size: 0.83em;
    vertical-align: super;
    line-height: 0;
}

kbd {
  display: inline-block;
  padding: 3px 5px;
  font-size: 11px;
  line-height: 10px;
  color: #555;
  vertical-align: middle;
  background-color: #fcfcfc;
  border: solid 1px #ccc;
  border-bottom-color: #bbb;
  border-radius: 3px;
  box-shadow: inset 0 -1px 0 #bbb
}

* {
	-webkit-print-color-adjust: exact;
}
@media screen and (min-width: 914px) {
    body {
        width: 854px;
        margin:0 auto;
    }
}
@media print {
	table, pre {
		page-break-inside: avoid;
	}
	pre {
		word-wrap: break-word;
	}
}
</style>


</head>

<body>

<p align="center">
    <img src="./screenshots/applet_code.jpg" alt="小程序码" width="250">
</p>
<p align="center">
  码云博客 第三方小程序
</p>

<h2 id="toc_0">概述</h2>

<p><a href="https://gitee.com/normalcoder/Gitee-Blog-Applets">码云博客小程序</a> 是 <a href="https://blog.gitee.com/">码云博客</a> 的小程序版本实现。</p>

<p>小程序后端是基于 <a href="https://gitee.com/wext/wext-server-thinkphp3.2">Wext-server-thinkphp3.2</a> 实现的数据爬虫，使用 <a href="http://thinkphp.cn">ThinkPHP3.2</a> 框架开发。<a href="https://gitee.com/wext/wext-server-thinkphp3.2">Wext-server-thinkphp3.2</a> 是集成小程序账号体系的快速开发Demo。</p>

<p>小程序前端使用ES6+小程序原生语法，基于 <a href="https://github.com/youzan/zanui-weapp">ZanUI WeApp</a> 和 <a href="https://gitee.com/wext/wext">Wext</a> 开发的小程序应用。<a href="https://github.com/youzan/zanui-weapp">ZanUI WeApp</a> 是有赞移动 Web UI 规范 ZanUI 的小程序现实版本。<a href="https://gitee.com/wext/wext">Wext</a> 是针对小程序API和部分JS功能实现封装的小程序组件。</p>

<h2 id="toc_1">截图预览</h2>

<p align="left">
    <img src="./screenshots/index-01.png" alt="" width="300">
    <img src="./screenshots/index-02.png" alt="" width="300">
    <img src="./screenshots/detail.png" alt="" width="300">
    <img src="./screenshots/about.png" alt="" width="300">
</p>

<h2 id="toc_2">下载</h2>

<div><pre><code class="language-bash">git clone https://gitee.com/normalcoder/Gitee-Blog-Applets.git</code></pre></div>

<h2 id="toc_3">目录结构</h2>

<div><pre><code class="language-none">│   client  小程序端代码
│   server  服务端代码
│   screenshots  效果截图</code></pre></div>

<h2 id="toc_4">使用</h2>

<ul>
<li>小程序账号申请、小程序后台配置和使用语法请自行查阅 <a href="https://mp.weixin.qq.com/debug/wxadoc/dev/">小程序简易教程</a>、<a href="https://mp.weixin.qq.com/debug/wxadoc/dev/framework/MINA.html">小程序框架介绍</a></li>
<li>注册申请小程序，从小程序账号后台获得小程序的 <strong>appid</strong> 和 <strong>appsecret</strong>，同时配置业务域名和请求域名。</li>
<li>通过 <code>server\database\</code> 下的SQL文件导入数据库到MySQL</li>
<li>通过 <code>server\application\Common\Conf\db.php</code> 配置修改数据库连接</li>
<li>通过 <code>server\application\Common\Conf\miniapp.php</code> 配置修改小程序 <strong>appid</strong> 和 <strong>appsecret</strong></li>
<li>修改小程序项目配置文件 <code>client\project.config.json</code> 中的 <strong>appid</strong> 为开发者自己的小程序appid</li>
<li>通过「微信开发者工具」将 <code>client</code> 目录导入为小程序项目即可</li>
</ul>

<h2 id="toc_5">相关项目/参考网址</h2>

<p><a href="https://blog.gitee.com/">码云博客</a>、<a href="https://gitee.com/wext/wext">Wext</a>、<a href="https://gitee.com/wext/wext-server-thinkphp3.2">Wext-server-thinkphp3.2</a>、<a href="https://github.com/youzan/zanui-weapp">ZanUI WeApp</a>、<a href="https://mp.weixin.qq.com/debug/wxadoc/dev/">小程序简易教程</a>、<a href="https://mp.weixin.qq.com/debug/wxadoc/dev/framework/MINA.html">小程序框架介绍</a></p>




</body>

</html>
